using Grand.Domain.Localization;
using Grand.Domain.Seo;
using Grand.Domain.Stores;

namespace Grand.Domain.Blogs;

/// <summary>
///     Represents a blog post
/// </summary>
public class BlogPost : BaseEntity, ISlugEntity, IStoreLinkEntity, ITranslationEntity
{
    /// <summary>
    ///     Gets or sets the blog post title
    /// </summary>
    public string Title { get; set; }

    /// <summary>
    ///     Gets or sets the picture identifier
    /// </summary>
    public string PictureId { get; set; }

    /// <summary>
    ///     Gets or sets the blog post body
    /// </summary>
    public string Body { get; set; }

    /// <summary>
    ///     Gets or sets the blog post overview. If specified, then it's used on the blog page instead of the "Body"
    /// </summary>
    public string BodyOverview { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether the blog post comments are allowed
    /// </summary>
    public bool AllowComments { get; set; }

    /// <summary>
    ///     Gets or sets the total number of comments
    ///     <remarks>
    ///         We use this property for performance optimization (no SQL command executed)
    ///     </remarks>
    /// </summary>
    public int CommentCount { get; set; }

    /// <summary>
    ///     Gets or sets the blog tags
    /// </summary>
    public string Tags { get; set; }

    /// <summary>
    ///     Gets or sets the blog post start date and time
    /// </summary>
    public DateTime? StartDateUtc { get; set; }

    /// <summary>
    ///     Gets or sets the blog post end date and time
    /// </summary>
    public DateTime? EndDateUtc { get; set; }

    /// <summary>
    ///     Gets or sets the meta keywords
    /// </summary>
    public string MetaKeywords { get; set; }

    /// <summary>
    ///     Gets or sets the meta description
    /// </summary>
    public string MetaDescription { get; set; }

    /// <summary>
    ///     Gets or sets the meta title
    /// </summary>
    public string MetaTitle { get; set; }

    /// <summary>
    ///     Gets or sets the sename
    /// </summary>
    public string SeName { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether the entity is limited/restricted to certain stores
    /// </summary>
    public virtual bool LimitedToStores { get; set; }

    public IList<string> Stores { get; set; } = new List<string>();

    /// <summary>
    ///     Gets or sets the collection of locales
    /// </summary>
    public IList<TranslationEntity> Locales { get; set; } = new List<TranslationEntity>();
}